#include <bits/stdc++.h>

using namespace std;

const int N=110;

int n,m;
int mp[N][N];

int main()
{
 	cin>>n>>m;
 	memset(mp,0x3f,sizeof mp);
 	for(int i=1;i<=n;i++) mp[i][i]=0;
 	
 	for(int i=1;i<=m;i++)
 	{
 		int u,v,w;cin>>u>>v>>w;
 		mp[u][v]=min(mp[u][v],w);
 		mp[v][u]=min(mp[v][u],w);
	}
 	
 	for(int k=1;k<=n;k++)
 	{
 		for(int i=1;i<=n;i++)
 		{
 			for(int j=1;j<=n;j++) mp[i][j]=min(mp[i][j],mp[i][k]+mp[k][j]);
		}
	}
 	
 	for(int i=1;i<=n;i++)
 	{
 		for(int j=1;j<=n;j++) cout<<mp[i][j]<<" ";
 		cout<<endl;
	}
 	
	return 0;
}
